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ABSTRACT 


An  error  ellipse  plotting  routine  was  developed  to 
provide  real-time  indication  of  Kalman  filter  performance. 
The  study  included  an  evaluation  of  the  Hewlett-Packard  HP-86 
computer  system's  capability  for  providing  real-time 
tracking  information  and  an  evaluation  of  the  computer's 
possible  use  on  the  three-dimensional  underwater  tracking 
range  at  the  Naval  Underwater  Weapons  Engineering  Station, 
Keyport ,  Washington.   A  series  of  tracking  runs  were  used 
to  demonstrate  both  linear  and  extended  Kalman  filtering. 
Information  obtained  from  the  error  ellipses  was  used  to 
modify  filter  parameters  for  improved  filter  performance. 
It  was  found  that  the  error  ellipse  was  useful  as  a  tool 
for  indicating  filter  performance  and  for  making  decisions 
regarding  filter  parameter   modification.   The  HP-86  provided 
accurate,  reliable  results  and  it  could  be  used  for  on-line 
graphics.   However,  the  computing  speed  fo  the  HP-86  computer 
as  used  in  this  study  was  too  slow  for  on-line  processing 
of  the  three-dimensional  tracking  problem. 
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I.   INTRODUCTION 

The  Kalman  filter's  importance  as  an  estimator  and 
predictor  is  well  documented.   Providing  real-time  informa- 
tion concerning  filter  performance  so  that  on-line  adjust- 
ments to  filter  parameters  can  be  made  continues  to  be  an 
area  of  high  interest.   This  study  investigates  the 
usefulness  of  the  error  ellipse  as  a  tool  for  providing  a 
real-time  indication  of  filter  performance. 

Part  of  the  investigation  involves  an  evaluation  of  the 
Hewlett-Packard  HP-86  computer  system's  capacity  to  operate 
in  a  real  time  tracking  environment,  and  its  capabilities  for 
providing  information  concerning  filter  performance.   The 
rationale  behind  this  investigation  is  based  on  the  require- 
ment for  the  Naval  Underwater  Weapons  Engineering  Station, 
Keyport,  Washington,  to  accurately  acoustically  track 
torpedoes  on  a  three-dimensional  underwater  tracking  range. 
A  knowledge  of  the  range  operation  is  not  within  the  scope 
of  this  study.   It  is  sufficient  to  know  that  presently 
the  range  receives  four  time  measurements  every  1.31  seconds, 
and  these  measurements  are  nonlinear  functions  of  the 
torpedo  position. 

To  gain  a  better  understanding  of  the  error  ellipse,  a 
M--state  tracking  scenario  was  chosen  for  this  study. 


Initially,  the  linear  tracking  problem  is  discussed, 
followed  by  an  investigation  of  the  nonlinear  problem.   Of 
primary  interest  are  on-line  methods  to  improve  filter 
performance  using  information  provided  by  the  error  ellipse 
for  filter  parameter  modification. 


II.   KALMAN  FILTER  THEORY 

A.   LINEAR  MATHEMATICAL  MODEL 
1.   The  Plant 

For  this  model  the  state  and  measurement  equations 
for  the  plant  are  linear.   Hence  the  discrete  form  is  used. 
The  assumed  plant  model  is  described  by  a  linear,  vector 
difference  equation: 

x(k+l)  =  J>x(k)  +  A_u(k)  +  £w(k)    (State  Equation)    (2-1) 

and  a  linear,  vector  measurement  equation: 

z(k)  =  cx(k)  +  v(k)  (2-2) 


where : 

x(k)    is  an  n-dimensional  column  vector,  denoting  the 
state  of  the  plant  at  "time"  k. 

u(k)    is  the  deterministic  control  input,  an  m-vector, 
at  time  k. 

w(k)    is  a  p-dimensional  vector  representing  any  random 
forcing  inputs  at  time  k. 

z_(k)    is  a  q-dimensional  vector  representing  measure- 
ments made  at  time  k. 

v(k)    is  a  q-dimensional  vector  representing  random 
measurement  made  at  time  k. 

i'  A_,  r_,  and  c  are  assumed  constant  coefficient  matrices  of 

dimension  nxn ,  nxm ,  nxp ,  and  qxn  respectively. 


2 .   Noise  Processes 

In  order  to  place  probabilistic  structure  on  the 
noise  processes  v(k)  and  w(k)  the  following  assumptions  are 
made  : 

(a)  v(k)  and  w(k)  are  individually  white  processes, 
that  is,  for  any  k  and  1,  with  k  f-    1,  v(k)  and 
v(l)  are  independent  random  variables,  and  w(k) 
and  w(l)  are  independent  random  variables. 

(b)  v(k)  and  w(k)  are  individually  zero  mean, 
Gaussian  processes  with  known  covariances. 

(c)  v(k)  and  w(k)  are  independent  processes. 
Thus  for  the  measurement  noise: 

MEAN:     E[y_(k)]  =  0_  (k  =  0  , 1 ,  2  ,  3  ,  .  .  . )  (2-3) 

CO VARIANCE:    E[v(k)vT(l)]   =   E[v(k) ]E[ vT( 1) ] 


A 


0     k  i    1 


Rn     k  =  1 

-k 


or  E[v(k)vT  (1)]  =  Rk5kl    (k, 1=0, 1,2,  . . . )       (2-4) 


where  5,  .,  is  the  Kronecker  delta  function  defined  as 
kl 


=  0,  k  i    1 

6kl   { 
K1     =  1,  k  =  1 
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Likewise  for  rhe  random  forcing  input 


ECw(k)]  =0  (k=0,I,2,3,. . .)  (2-5) 


E[w(k)wT  (1)]  =  Qk  6       k, 1  =  0, 1,2, 3, . . .)  (2-6) 


Q,  and  R   are  nonnegative  definite  symmetric  for  all 
k.   Also  since  v(k)  and  w(k)  are  zero  mean  and  independent 
then: 


E[v(k)wT  (1)]   =   0  (2-7) 


For  the  purposes  of  this  study,  unless  otherwise 

specified  Q   and  R,  are  considered  to  be  known  and  constant, 

— k      —  k 

although  both  may  be  time  varying. 

3  .   Initial  State  Description 

For  the  initial  state  of  the  difference  equation  (2-1) 

it  is  unlikely  that  x   will  be  available.   Hence,  it  is 

J  — o  ' 

assumed  that  x   is  a  Gaussian  random  variable  of  known  mean 

— o 

x   and  known  covariance  P  ,  i.e., 
— o  — o 


ECx(O)]   =   x 


E{[(x   -  x  )][(x   -  x  )]T}   =  P 
— o    —  o     — o    — o        — o 
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This  choice  for  the  initial  state  has  the  advantage 
of  causing  the  subsequent  estimation  scheme  to  be  unbiased 
for  all  t.   [Ref.  1]   Further  it  is  assumed  that  the  initial 
state  and  the  measurement  noise  are  uncorrelated : 


E[x(0)vT  (k)]   =   E[v(k)xT(0)]   =   0  (k= 0 , 1 , 2 , 3 , . . . ) 


Also  the  initial  state  and  the  random  forcing  input  are 
uncorrelated : 


E[x(0)wT  (k)]   =   E[w(k)xT  (0)]   =   0  (k=0,l,2,3, . . .) 


B.   DISCRETE-TIME  ESTIMATION 

1 .   The  Estimator  Equations 

The  estimation  problem  involves  generating  an 
optimal  estimate  for  x  (  j  )  for  the  system  described  by  the 
difference  equation  (2-1)  from  the  noisy  measurements 
z_(  0)  ,z_(  1)  ,  .  .  .  ,z_(  j  )  .   This  estimate  will  be  denoted  by 

A 

x(j/j),  which  means  the  estimate  of  x  at  time  j  given 
measurements  at  times  up  to  and  including  time  j .   The 
estimate  must  be  optimal  in  the  sense  that  the  expected 
value  of  the  sum  of  the  squares  of  the  error  in  the  estimate 
is  a  minimum,  i.e.: 

E{[(x(k/k)  -  x(k)]T[x(k/k)  -  x(k)]}  =  minimum 
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The  estimator  is  characterized  by  the  linear  relationship: 

x(k/k)  =  x(k/k-l)  +  G(k)Cz(k)  -  cx(k/k-l)]  (k=0 ,1, 2 , . . ) 

(2-8) 


where 


x(k/k)      is  the  optimal  (minimum  variance)  estimate  of 
x(k)  given  observations  at  times  up  to  and 
including  k. 

x(k/k-l)    is  the  optimal  one-step  prediction  of  x(k) 
given  observations  at  times  up  to  and 
including  k-1. 

G(k)        is  the  optimal  estimation  gain  matrix  which 
will  minimize  the  variance  of  estimation 
error . 


For  the  initial  estimate  x(0/0),  the  estimator 
equation  (2-8)  is  initialized  with  x(0/-l),  which  is  not  a 
random  variable.   If  x(0/-l)  is  selected  such  that: 


x(0/-l)  =  E[x(0)]   =   x 
—  —         — o 


it  can  be  shown  that  this  choice  of  x(0/-l)  makes  the 
estimator  unbiased  for  all  k.  [Ref.  1]   The  estimators  best 
available  information  concerning  x(k-l)  is  the  estimate 
x(k-l/k-l) ,  therefore  it  is  reasonable  to  assume  that 

x(k/k-l)  =  ^x(k-l/k-l)  +  Au(k-l)  (2-9) 

is  the  best  prediction. 
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In  summary,  equations  (2-8)  and  (2-9)  are  the  estimator 

equations,   with  x(0/-l)  =  x   as  the  initial  condition. 
^  —         — o 

2 .   Gain  and  Covariance  Equations 

Without  going  into  detailed  derivations ,  the  optimal 
estimator  gains,  G(k),  used  in  the  estimator  equation  (2-8), 
are  those  which  satisfy: 


G(k)  =  P(k/k-l)CT[CP(k/k-l)CT  +  R]  X  (2-10) 


P(k/k)  =  [I  -  G(k)C]P(k/k-l)  (2-11) 


P(k  +  l/k)  =  <j>P(k/k)  $T    +  Q  (2-12) 


with  the  initial  conditions 


PC0/-1)  =  P   =  E{[x(0)  -  x  ][x(0)  -  x  ]T} 
—         — o       —      — o   —      — o 


where 


I 


P(k/k)  =  E{[x(k/k)  -  x(k)][x(k/k)  -  x(k)]  } 


is  the  covariance  of  estimation  error  matrix. 
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P(k/k-l)  =  E{[x(k/k-l)  -  x(k)][x(k/k-l)  -  x(k)]  } 


is  the  covariance  of  one-step  prediction  error  matrix 


2   =    E[r_(k).w(k)-wT  (k)TT  (k)] 


is  the  state  excitation  matrix. 

P(k/k)  and  P_(k/k-l)  are  symmetric,  positive  definite  matrices. 
Several  observations  can  be  made  concerning  the  linear 
Kalman  gain  (2-10),  covariance  (2-11,  2-12)  and  estimator 
( 2 -8 )  equations . 

(a)  The  estimator  gains,  G(k),  do  not  depend  on  the 
measurement  data  and  hence  can  be  precomputed ,• stored ,  and 
used  as  the  processing  measurements  become  available. 

(b)  Although  not  obvious  from  the  equation,  the 
time-varying  gain,  G(k)  ,  depends  in  time  as: 


G<k)  =  H7-r-=rs  [Ref.  2]  (2-13) 

—       (k  +  1) 


Thus  the  effect  is  to  weight  the  correction  term, 
[z_(k)  -  cx(k/k-l)],  in  the  estimator  equation  (2-8)  less 
heavily  as  time  progresses.   The  advantage  of  a  greater 
initial  weight  allows  for  possibly  large  differences 
between  _z(k)  and  x(k/k-l)  during  the  initial  observations, 
and  a  large  gain  will  result  in  a  significant  change  in  the 
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next  estimate.   This  advantage  is  also  borne  out  in  that 
there  is  less  confidence  in  the  quality  of  the  estimates 
during  the  early  observations  compared  with  the  quality 
after  numerous  observations.   Hence  the  later  an  observation, 
the  less  drastic  an  estimate  will  be  altered  or  affected  by 
an  isolated  observation  discrepancy. 

(c)  In  general,  the  variance  of  estimation  error 

decreases  in  a  manner  analogous  to  the  gain  schedule  (2-13), 

i.e.,  it  decreases  as  k  grown  larger,  reflecting  greater 

confidence  in  the  estimate  as  the  number  of  observations 

increases.   Selection  of  the  proper  initial  condition,  P  , 

is  important  when  studying  the  effect  of  measurement  errors 

on  the  behavior  of  the  estimate.   So  P   should  be  assigned 

— o  ° 

pessimistic  values  which  would  correspond  to  a  lack  of 
information  about  the  initial  state.   In  cases  when  the 
initial  state  is  completely  unknown,  then  P  ->°°I.  [Ref.  3] 

(d)  The  Q  matrix  serves  to  compensate  for  model 
errors  and  prevents  the  covariance  matrix  from  becoming  too 
small  or  optimistic.   A  small  covariance  matrix  would  result 
in  a  small  filter  gain,  and  subsequent  observations  are 
essentially  ignored,  which  could  result  in  filter  divergence. 
The  Q  matrix  prevents  G(k)  from  approaching  zero  by  adding 
uncertainty  to  the  system  which  is  reflected  in  a 
degradation  of  certainty  (increase  in  P(k+l/k)). 
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C.   NONLINEAR  ESTIMATION  -  EXTENDED  KALMAN  FILTER 

In  many  practical  applications,  the  state  equations 
and/or  measurement  equations  are  nonlinear.   Before  the 
Kalman  filter  equations  can  be  used,  the  problem  must  be 
linearized  and  the  Kalman  filter  equations  are  applied  with 
some  modification. 

1 .   Nonlinear  Model 

Consider  a  nonlinear  discrete  system  of  state  and 
observation  equations  given  by: 

x(k+l)   =   f(x(k),  u(k),k)  +  w(k)  (2-14) 


and 


z(k)  =  h(x(k),  k)   +   v(k)  (2-15) 


In  these  equations  f  and  h  are  nonlinear  functions 
of  the  state  variable  x,  w(k)  is  the  plant  excitation  noise, 
and  v(k)  is  the  measurement  noise.   The  plant  noise  and 
measurement  noise  are  assumed  to  be  uncorrelated ,  zero-mean, 
and  white.   The  same  equations  (2-3  thru  2-7)  apply  as  for 
the  linear  model. 

2 .   Extended  Kalman  Filter  Equations 

In  order  to  apply  the  linear  filter  equations , 

equations  (2-14)  and  (2-15)  are  expanded  about  the  best 

estimate  of  the  state  at  that  time  and  only  the  first-order 

terms  are  kept. 
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That  is,  defining  A(k)  as: 


A(k)   =  ~ 


3x 


(x(k/k) ,  u(k)  ,  k) 


and 


H(k) 


3h 
3x 


(x(k/k-D) 


As  can  be  seen  from  the  above  equations,  the  filter 
estimates,  x(k/k)  and  x(k/k-l)  are  used  as  the  "best" 
estimates  about  which  the  linearization  is  performed.   The 
matrices  A(k)  and  H(k)  must  be  used  to  generate  G(k)  so  it 
is  available  to  process  z_(k)  when  it  is  obtained.   The 
modified  extended  Kalman  filter  equations  are  then: 

Gain  Equation: 


(k)  =  P(k/k-l)HT  (k)CH(k)  •  P(k/k-l)  •  HT  (k)  +  R]"1 


Filter  Update  Equation 


(2-16) 


x(k/k)  =  x(k/k-l)  +  G(k)[z(k)  -  h(x(k/k-l))] 


(2-17) 
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Prediction  Equation 


x(k+l/k)  =  f(x(k/k),  u(k),  k)  (2-13) 


Covariance  of  Estimation  Error  Equations 


P(k/k-l)  =  A(k-l)P(k-l/k-l)AT(k-l)  +  Q(k-l)  (2-19) 


P(k/k)  =  [I  -  G(k)H(k)]P(k/k-l)  (2-20) 


For  the  initial  estimate  x(0/0),  equation  (2-17)  is 

A 

initialized  with  x(0/-l)  with 


x(0/-l)  =  ECx(O)]   =   x 
—  —         — o 


x(0/-l)  is  also  used  to  initially  evaluate  H(k) 
As  in  the  linear  case: 


PC0/-1)  =  P   =  E[(x   -  x  )][(x   -  x  )T] 
—         — o       — o    — o     — o    — o 
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Ill .   ERROR  ELLIPSOIDS 

A.   THEORY 

Since  the  estimate  x(k/k)  is  unbiased  in  the  Kalman 
filter  equations,  the  P(k/k)  matrix  represents  the  covariance 
of  the  error  in  the  estimate.   If  the  estimate  were  biased, 
P_(k/k)  would  represent  the  second-moment  matrix  rather  than 
the  covariance  matrix.   Hence,  P(k/k)  provides  significant 
information  about  the  accuracy  of  the  estimate.   If  the 
physical  model  is  accurately  described  by  the  state  and 
measurement  equations  (2-1,  2-2),  then  P(k/k)  can  be  used 
to  describe  the  manner  in  which  the  estimate  converges 
(or  diverges)  to  the  true  state.   Examination  of  the  P(k/k) 

matrix  directly,  element  by  element,  is  not  a  realistic 

2 
approach,  since  the  matrix  contains  n   elements,  wnere  n  is 

the  number  of  state  variables.   To  simplify  the  situation 

the  concept  of  the  error  ellipsoid  is  used.  [Ref.  4] 

As  discussed  earlier,  the  assumptions  are  made  that  the 

initial  state  of  the  plant  x   is  Gaussian,  as  are  the  random 

r      -o 

processes  v(k)  and  w(k) .   Using  these  assumptions  it  follows 
that  x(k)  and  x(k/k)  are  also  Gaussian  since  they  are  linear 
combinations  of  Gaussian  variables  and  deterministic 
quantities.   Using  the  same  rationale,  the  estimation  error, 
defined  as: 
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e(k/k)  =  x(k/k)  -  x(k) 


is  also  Gaussian.   Using  the  fact  that  the  mean  of  the 
estimation  error  is  0,  the  probability  density  function  for 
e(k/k)  is: 


pe[e(k/k)]  =  [(2u)n/2|P(k/k)| 1/2]_1 


exp[-l/2ei  (k/k)P~  (k/k)e(k/k)]         (3-1) 


The  density  function,  p  [e(k/k)]  will  have  a  constant 
value  whenever  the  exponent  has  a  constant  value.   That  is: 


-l/2eT  (k/k)P  X  (k/k)e(k/k)  =  c 


or 


eT  (k/k)P  1(k/k)e(k/k)  =  c2  (3-2) 


where  c  is  an  arbitrary  constant. 

As  demonstrated  by  Sorenson  [Ref.  1]  and  Kirk  [Ref.  2], 

it  can  be  shown  that  the  locus  of  points  e_(k/k)  which 

satisfy  equation  (3-2)  are  hyperellipsoids .   For  the 

two-dimensional  case  which  is  of  concern,  equation  (3-2) 

describes  an  ellipse.   This  can  be  seen  by  fixing  time  and 

rewriting  (3-2)  as: 
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eTwe  =  c2  (3-3) 


where 


w  =  P    (k/k)    (a  2  x  2  symmetric  matrix) 


Expanding  the  left  side  of  (3-3)  gives 


Wllel  +  W12W21ele2  +  W22e2  =  ^ 


which  because  of  symmetry  gives: 


2  2 

w,-.e   +  2w,„e  e„  +  w?2e2  =  c  (3-4) 


2 
Since  w  >0,  w„2>  0,  and  w,  ,  w  >w   ,  equation  (3-4) 

describes  an  ellipse,  in  which  the  principal  axes  do  not 

coincide  with  the  coordinate  axes .   The  ellipse  is  rewritten 

in  terms  of  y(l)  and  y ( 2 )  as  the  coordinate  axis,  and  it  can 

be  shown  that  y(l)  and  y  (  2  )  are  the  eigenvectors  of  w   with 

A,  and  X      defined  as  the  corresponding  eigenvalues.  [Ref.  2] 

(See  Figure  3-1).  The  equation  for  the  ellipse  can  be 

rewritten  in  terms  of  a  coordinate  system  having  unit  vectors 

in  the  directions  of  y(l)  and  y ( 2 )  as  the  basis  vectors. 

The  ellipse  equation  becomes : 

X-j^CD  +  A2y2(2)  =  c2  (3-5) 
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Figure  3-1   Error  Ellipse 


Remembering  that  w  =  P   (k/k) ,  it  can  be  shown  that  rhe 
corresponding  eigenvectors  and  eigenvalues  for  w   =P(k/k) 
are  y(l),  y(2),  ou  ,  and  a0  ,    where  a.   =  - —  and  ot0  =  - — . 
Equation  (3-5)  can  be  rewritten: 


y  2  ( 1 )      y  2  (  2  ) 

+   


Cl- 


Ot, 


=  c 


(3-6) 
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For  the  purposes  of  this  study,  the  term  error  ellipsoid 
refers  to  the  specific  case  when  c  =  1.   So  equation  (3-6) 
becomes : 

y2(l)     y2(2) 


+  =   1 


al        a2 


In  terms  of  the  Cartesian  coordinates  xf,  y',  which  use  e. 


and  e?  as  basis  vectors 


x'  =  xcosG  +  ysin9 
y'  =  -xsinB  +  ycos0 


where  9  is  the  angle  of  rotation  of  the  axes  and  can  be 
computed  from: 


,  2cov(e    e    ) 

9    =    1/2    tan_1[    2LJ2 ]  [Ref.    5] 

var(e    )    -    var(e    ) 
x  y 


For  a  given  value  of  c  it  is  possible  to  integrate  the 
probability  density  over  the  surface  of  the  error  ellipse  to 
obtain  the  probability  that  a  particular  sample  point  will 
lie  within  the  ellipsoid.   For  this  study,  n  =  2,  c  =  1, 
and  the  probability  the  error  is  inside  the  ellipse  is  0.39M-. 

In  summary,  the  error  ellipsoid  can  be  used  to 
characterize  the  concentration  of  the  estimate  about  the 
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true  value  of  the  state.   A  decrease  in  the  magnitude  of  an 
axis  of  the  ellipse  is  an  indication  that  the  error  in  the 
estimate  is  decreasing  in  that  direction. 

One  important  item  that  needs  to  be  pointed  out  is  that 
often  the  components  of  the  state  vector  represent  entirely 
different  types  of  variables,  for  example  the  components 
might  represent  range,  velocity,  and  depth.   Since  the  two- 
dimensional  ellipses  are  determined  by  using  two  components 
of  the  state  vector,  it  is  reasonable  to  examine  submatrices 
relating  state  variables  of  the  same  character.   Doing  so 
will  preclude  most  scaling  difficulties  when  plotting  the 
ellipses,  and  provide  more  meaningful  insight  in  to  the 
results . 

B.   ERROR  ELLIPSOIDS  AND  FILTER  DIVERGENCE 

Thus  far  the  discussion  has  centered  around  using 

submatrices  of  the  P(k/k)  covariance  of  estimation  error 

matrix  as  the  input  for  the  error  ellipse  to  indicate 

filter  performance.   As  proposed  by  Heffes  [Ref »  6]  and 

Nishimura  [Ref.  7],  P(k/k)  can  be  considered  as  a  "design" 

covariance  matrix  P  ,  using  the  assumption  that  the  only 

errors  are  in  0,  ,  R,  ,  and  P   with  the  following  ineaualities 

— k  — k '     — o  & 

holding  for  all  k: 


0?  >  Q?  ,  R^    R*    Pd    Pa  rq  7, 

-^k  —  -^k  '  — k  —  — k    — o  —  — o  (  3  -  7 ) 
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with  the  subscript  Md"  indicating  designed  and  "a"  indicating 
actual.   Equation  (3-7)  implies  more  input  noise,  mere 
measurement  noise,  and  more  initial  state  uncertainty  in  the 
design  than  actually  exists.   This  conservative  filter  design 
results  in  a  somewhat  pessimistic  design  error  covariance 
P  (k/k) .   The  actual  error  covariance  P  (k/k)  resulting 
from  using  a  filter  designed  with  Q  ,  R  ,  and  P   is  related 
to  the  design  error  covariance  in  the  following  manner: 


Pd(k/k)  >  Pa(k/k) 


This  result  is  particularly  useful  when  one  simply  does 
not  know  accurately  the  noise  covariance  of  the  input  or 
output,  but  an  upper  bound  is  known.   Designing  assuming 
the  noise  covariance  is  at  its  upper  bound  will  result  in 
P  (k/k)  being  upper  bounded  by  P  (k/k) .   In  some  sense  a 
worst  case  design  results.   Filter  divergence  exists  when 
the  design  error  covariance  P  (k/k)  remains  bounded  while 
the  error  performance  matrix  P_  (k/k)  becomes  very  large 
relative  to  P  (k/k)  or  is,  in  fact,  unbounded. 
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IV.   PROBLEM  DEFINITION 

A.   PROBLEM  DESIGN 

The  purpose  of  the  tracking  problem  is  to  study  the  use 
of  error  ellipsoids  as  real-time  indicators  of  filter 
performance.   In  order  to  keep  the  design  model  realistic 
albeit  reasonably  simplified  for  ease  of  study,  a 
two-dimensional  tracking  problem  using  several  different 
tracks  has  been  selected. 

1 .   Linear  Tracking 

All  tracks  are  based  on  an  x-y  coordinate  system 
with  the  target  moving  in  the  x  or  y  direction  relative  to 
the  sensor  located  at  the  origin.   Thus  for  aircraft 
tracking,  altitude  is  considered  constant,  as  is  depth  for 
torpedo  tracking. 

Defining  the  state  variables  as: 

x,  =  x     x-coordinate  of  the  target  location. 

x~  =  x     velocity  of  target  (v  )  in  x-direction. 
2  °      x 

x-  =  y     y-coordinate  of  the  target  location. 
xu  =  y     velocity  of  target  (v  )  in  y-direction. 
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resulting  in  a  state  vector 


x  = 


X 
X 

y 

y. 


(4-1) 


(4-2) 


The  following  are  the  state  equations 


x1(t)  =  x2(t) 


x2(t)  =  W  (t) 


x3(t)  =  x^(t) 


x^(t)  =  w2(t) 


where  w,(t)  and  w„(t)  are  assumed  to  be  uncorrelated , 
random  processes  that  account  for  unknown  target  accelerations 
and  nonlinear  target  motions.   Writing  the  discrete  form  of 
the  state  equations  gives: 
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x_(k+l)  =  x,(k)  +  T  •  x.Ak)    +  J-  '  w,  (k) 

l  1  2       2     1 


x2(k+l) 


x0(k+l) 


x2(k)  +  T 


(k)  +  T 


w1(k) 


x4(k)  +  L 


.2 


(k) 


(4-3) 


or 


x^Ck+1)  =  x  (k)  +  T  •  w2(k) 


x(k+l)  =  <{)x(k)  +  rw(k) 


(4-4) 


With  T,  the  sampling  period  equal  to  1  second,  the  matrices 
cj)  and  r  are : 


<J>  = 


110   0 


0   10   0 


0   0   11 


0   0   0   1 


r  = 


5 

0 

1 

0 

0 

.5 

0 

1 

(4-5) 


It  is  assumed  that  the  sensor  gives  noisy,  but 
uncorrelated  measurements  of  x  and  y.   Hence  the  discrete 
measurement  equations  are: 
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z-^k)  =  x1(k)  +  v1(k) 


z2(k)  =  x3(k)  +  v2(k) 


with  v,(k)  and  v_(k)  uncorrelated  random  noise 
Thus  for  the  measurement  equation: 


(4-6) 


z(k)  =  cx(k)  +  v(k) 


(4-7) 


the  matrix  c  is 


c  = 


10    0    0 


0    0    10 


For  the  initial  run  and  unless  otherwise  noted  the 
following  values  for  the  Gaussian  random  processes  will  be 
used : 

E[v(k) ]  =  0  for  all  k 


E[v(k)vi(k)]  = 


20x10      0 


20x10 


2 

m   =  R  for  all  k 
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a 
— v 


150 


150 


m  =  the  standard  deviation  of 


measurement  noise. 


ECw(k) ]  =  0  for  all  k 


E[w(k)w  (k)]  = 


100     0 


0       100 


2  2 
(m/sec  )   =  cov  w  for  all  k 


a 
— w 


10 


10 


m/sec   =  the  standard  deviations  of  the 


random  forcing  input. 


The  covariance  of  estimation  error  matrix  is  initialized 


P  =P(0/-1) 
— o  — 


-io2 

0 

0 
0 


0 

0 

0 

102 

0 

0 

0 

102 

0 

0 

0 

1 
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Since  the  filter  is  to  be  unbiased,  the  initialization 


x(0/-l)  -    x      -    Initial  condition  of  the  problem 


— o 


2 .   Nonlinear  Tracking 

The  state  equations  are  the  same  as  for  the  linear 
tracking  problem.   The  measurement  equation  is  considered 
as  a  noisy  range  measurement  by  the  tracking  sensor  and  is 
characterized  as: 


z(k)  =  CxJ(k)  +  x^Ck)]172  +  v1(k) 


(4-8) 


Thus  z(k)  is  a  nonlinear  function  of  the  states.   Using 
equation  (2-14)  and  with  T  =  1  second: 


f(x(k)  ,  u(k)  ,  k)  = 


~x  (k)  +  x„(k)' 
x2(k) 
x3(k)  +  x  (k) 

_Vk) 
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Taking    partial    derivatives    of    f   with   respect    to   x    gives 


A(k)  = 


3f 

3x 


(x(k/k) ,    u(k) ,    k) 


110         0 


0  0 


0         0         11 


0         0  0  0 


=   4> 


using  equation  (2-15): 


2,,  x  -.1/2 


h(x(k)  ,  k)  =  [x£(k)  +  x,(k)] 


and  taking  the  partial  derivative  with  respect  to  x  gives 


3h 

H(k)  =  — 
—       3  x 


(x(k/k-D) 


x1(k) 


,  o, 


— 2      2     TT? 
x^(k)+X3(k)]1/Z 


x3(k) 
[x^CkHx^k)]172 


,  0 


x(k/k-l) 
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Using  the  above  results  with  the  same  values  for  the 
random  noise  processes  as  previously  stated  for  the  linear 
case,  the  extended  Kalman  filter  equations  can  now  be  applied 
to  the  nonlinear  tracking  problem. 

B.   COMPUTER  SIMULATION 

1 .   Computer  Hardware/Software 
a.   Hardware 

All  computer  simulations  were  run  on  the  Hewlett- 
Packard  HP-86  personal  computer.   This  particular  model  was 
chosen  to  evaluate  its  capabilities  in  determining  its 
usefulness  in  actual  torpedo  tracking  at  the  underwater 
tracking  range  at  Naval  Underwater  Weapons  Engineering 
Station,  Keyport ,  Washington.   The  HP-86  system  used  included 
keyboard,  9  inch  CRT  monitor  connected  through  an  integrated 
monitor  interface,  and  two  HP  Flexible  Disc  Drives  connected 
through  an  integrated  disc  interface.   Plotting  was  done  on 
a  HP-7225B  Plotter  and  printing  on  a  HP-2631G  Printer.   These 
peripherals  were  interfaced  using  a  HP-IB  Interface  module. 
Because  the  system  uses  interface  select  codes,  the  HP-IB 
factory  preset  code  was  set  at  7,  which  is  the  select  code 
for  the  printer/disc  interface.   This  code  however  did  not 
work  when  interfacing  with  the  external  plotter  and  printer, 
since  duplicate  select  codes  are  not  allowed.   So  the 
internally  set  select  code  of  the  HP-IB  was  set  to  8  for 
proper  system  operation. 
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b.   Software 

The  HP-86  has  60K  built-in,  useable  bytes  of 
computer  memory,  expandable  to  572K  using  either  32K,  54K, 
or  12 8K  Memory  Modules.   A  HP-86  plug-in  ROM  was  required 
to  operate  the  external  plotter.   Also  a  Matrix  ROM  was  used 
to  reduce  program  length  and  computer  run  time . 

All  programs  were  written  in  BASIC  programming 
language  using  REAL  (full)  precision,  which  provides  15  digit 
precision.   Appendix  B  provides  an  explanation  of  the  program 
options  and  Appendix  C  contains  the  program  listings  used  for 
this  study. 

2  .   Track  Generation 

To  evaluate  the  real-time  use  of  the  error  ellipse  as 
an  indicator  of  filter  performance,  Monte  Carlo  simulation 
runs  were  made.   Four  tracks  were  generated  by  separate 
programs  and  one  second  incremental  values  of  x,  y,  v  ,  and 
v   were  stored  in  data  files .   Appendix  I  contains  an 

y 

explanation  of  the  generation  of  tracks  three  and  four. 
3 .   Noise  Generation 

In  order  to  simulate  the  random  noise  processes,  the 
computer's  random  number  generator  was  used  and  the  generated 
numbers  scaled  accordingly.   For  each  track  and  each 
different  value  of  noise  sigma,  a  different  generator  "seed 
number"  was  used.   These  noise  values  produced  were  added  to 
the  applicable  true  track  values  to  simulate  a  sensor 
measurement  corrupted  by  independent  Gaussian  noise.   For  all 
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cases  where  filter  parameters  were  varied  for  a  particular 
track  under  a  specific  noise  condition,  one  noisy  track  was 
generated,  stored,  and  used  throughout  that  particular 
simulation.   This  was  done  for  ease  of  filter  performance 
comparison. 

4 .   Gating  Scheme 

In  order  to  preclude  catastrophic  filter  failure  due 
to  excessive  measurement  noise,  a  bound  was  established  for 
the  maximum  acceptable  limits  of  measurement  noise.   A 
three-sigma  gate  was  designed  using  the  covariance  of  the 
measurement  noise,  R,  and  the  predicted  covariance  of  error 
matrix  P(k/k-l).   The  gate  is  defined  as: 


Gate(k)  =  3(p..    (k/k-1)  +  R..)1/2 

max 


This  gate  is  the  maximum  error  allowable  for  the  measurement 
at  time  k.   If  the  absolute  difference  between  the  actual 
measurement  received  and  the  predicted  measurement  is 
greater  than  the  three-sigma  gate,  then  that  particular 
measurement  data  is  rejected  as  unacceptable.   When  this 
occurs,  the  filter  gain,  G(k),  is  set  to  zero,  resulting  in 
that  measurement  being  ignored  and  the  prediction  of  the 
states  set  equal  to  the  estimate,  that  is: 

x(k/k)  =  x(k/k+l) 
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5  .   Collection  of  Statistics 

In  order  to  study  error  ellipses  as  an  indicator  of 
filter  performance,  statistics  were  calculated,  on  line, 
after  each  measurement  during  the  Monte  Carlo  run.   The 
statistics  computed  were  relative  error  (in  some  cases  the 
error  was  normalized),  error  mean,  error  variance,  and  error 
covariance  for  the  positional  variables.   The  following 
equations  apply: 

Relative  Error  =  e(k/k)  =  x(k)  -  x(k/k) 


(filter  error  residual) 


k 


Error  Mean  =  e(k/k)  -  1/k   E   e(j/j) 


Error  Variance  =  VarCe . (k/k) ]  =  1/k   Z   [e. ( j / j ) ]-[e . (k/k) ] 

1  j=l    x 


1-X-.  ,  x~,  x~,  X. 


Positional 

Error 

Covariance 

Matrix 


VarCe   (k/k)] 
Xl 


k 
1/k  Z  [e   (j/j)][e   (j/j)] 
j=l   xl         X3 

-Ee   (k/k)-i"   (k/k)] 
xl       X3 


1/k  Z  [e  (j/j)][e   (j/j)]   VarCe   (k/k)] 
j=l  xl         3  3 

-Le   (k/k)-e   (k/k)] 


x 


1 


X. 


J 
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V.   TARGET  TRACKING  AND  ERROR  ELLIPSE  ANALYSIS 

A.   LINEAR  TRACKING 

Track  1  depicts  a  target  approaching  at  a  constant 

velocity  of  223.6  feet  per  second.   The  solid  line  of  Figure 

5.1  indicates  the  true  track  of  the  target  and  the  numbers 

along  the  track  indicate  the  time  in  seconds.   The  target 

was  tracked  in  a  measurement  noise,  a      -    150,  with  the 

— v 

random  forcing  noise  a      =  1.   R  was  set  for  20,000.   The 

— w       — 

dots  indicate  the  filtered  track  using  the  linear  Kalman 

filter  equations.   Figures  5.2  and  5.3  are  the  filter  error 

ellipses  for  this  run,  computed  at  increments  of  10  seconds. 

As  can  be  seen  the  ellipse  size  decreases  with  increasing 

time  indicating  filter  convergence.   The  computed  ellipse 

surface  areas  shown  on  the  figures  confirm  this.   Figure  5.4- 

shows  the  filtered  track  for  the  case  where  a      has  been 

—v 

increased  to  3  00  and  all  other  parameters  remain  the  same. 
The  error  ellipses  of  Figure  5.5  computed  for  10-second 
increments  show  increasing  area  indicating  filter  divergence 
Figure  5.5  shows  the  error  ellipses  for  the  same  track  run 
but  this  time  the  ellipses  were  computed  using  a  "statistics 
window"  of  10.   By  this  is  meant  that  the  ellipses  were 
derived  from  statistics  computed  for  the  last  10  data 
measurements.   All  previous  data  is  disregarded.   Using  this 
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method,  the  ellipses  of  Figure  5.6  show  filter  convergence 

from  iterations  15  to  25.   The  filtered  track  of  Figure 

5.4  confirms  this.   Figure  5.7  shows  the  results  for  The 

same  track  parameters,  except  in  this  case  a  statistics 

window  of  5  was  used.   The  window  5  ellipse  area  at  time 

25  (5179  sq  ft)  is  much  less  than  the  area  of  either  the 

run  with  the  statistic  window  of  10  (11,540  sq  ft)  or  the 

run  with  no  window  at  all  (55,500  sq  ft).   This  is  expected 

since  the  filter  is  essentially  "locked  on"  at  time  20, 

and  the  window  5  ellipse  at  time  2  5  disregarde   all  data 

previous  to  time  20.   Figure  5.8  shows  the  error  ellipses 

for  the  same  track  but  the  measurement  noise  was  increased 

to  o      =  400,  while  R  was  kept  at  20,000.   The  error  ellipses 

indicate  filter  divergence,  and  indeed  the  filtered  track 

headed  off  in  the  wrong  direction. 

Track  2  depicts  a  target  approaching  at  a  constant  speed 

of  500  feet  per  second  in  the  -y  direction.   Figure  5.9 

depicts  the  solid  line  track  and  the  dots  indicate  the  linear 

filtered  track  with  o      =  150,  a   =  1  and  R  =  20,000.   Figure 

— v        — w         — 

5.10  and  5.11  are  the  error  ellipses  for  the  run.   No 
statistics  window  was  used.   Other  than  the  fact  that  the 
ellipse  area  is  decreasing,  the  shape  of  the  ellipse  provides 
little  additional  information.   Figure  5.12  and  5.13  show  the 
ellipses  for  the  normalized  error.   With  the  same  measurement 
noise  sigma  for  both  the  x-position  and  y-position  measurements, 
the  normalized  error  ellipse's  shape  and  orientation  reflect 
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the  target  track  proximity  to  either  axis.   In  Figure  5.12 

the  ellipse  major  axis  indicates  a  large  normalized  error  in 

the  x-direction.   This  is  to  be  expected  since  the  target 

maintains  a  constant  x-position  of  500  feet,  while  the 

y-position  is  initially  20,000  feet.   However,  near  time  40 

as  the  target  approaches  the  x-axis,  the  normalized  y  error 

increases  and  becomes  so  large  at  the  x-axis  crossing  that 

the  normalized  x  error  becomes  insignificant  in  comparison. 

This  can  be  seen  in  Figure  5.13  for  the  ellipses  at  time 

45  and  55  compared  with  the  ellipse  at  time  35.   The 

normalized  error  ellipse  is  an  excellent  indicator  of 

target  proximity  to  an  axis,  but  the  rapid  shifts  in  ellipse 

surface  area  make  it  difficult  to  determine  filter 

convergence . 

Track  3  depicts  a  target  approaching  on  a  parabolic 

track  at  a  speed  of  200  feet  per  second.   Figure  5.14  is  the 

true  track,  with  a  linearly  filtered  track  indicated  by  the 

dots.   For  this  run  a    =150,  a  =10,  and  R=20,000.   Figure  5.15 

— v     '  — w         —  ° 

are  the  error  ellipse  plots  for  times  40,  50,  and  60,  the 
period  of  the  highest  rate  of  change  in  x-  and  y-velocity. 
The  ellipse  areas  increase  with  time  indicating  divergence. 
Figure  5,16  and  5.17  are  the  ellipse,  plots  using  a  10-data 
point  and  a  5-data  point  statistics  window  respectively. 
In  both  cases  the  ellipse  areas  for  time  60  are  less  than 
time  50  indicating  the  filter  has  tracked  around  the  curve. 
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Using  error  ellipses  based  on  a  statistics  window  in  this 
tracking  situation  provides  a  better  indicator  of  filter 
performance. 

For  the  second  run  of  track  3,  a_ ,  was  increased  to  300 
and  all  other  parameters  remained  the  same.   Figure  5.18 
shows  the  resulting  filtered  track,  which  obviously  didn't 
track  around  the  curve.   With  the  large  amount  of  measurement 
noise  and  considering  that  the  maximum  random  forcing  input, 
i.e.  the  maximum  acceleration  in  the  x-  and  y-direction, 
occurs  between  times  40  and  60,  it  is  a  logical  place  to  lose 
track.   Another  factor  to  be  considered  is  the  decrease  in 
gain  as  k  increases.   By  time  40  the  gains  have  little 
influence.   So  a  system  was  incorporated  in  the  program  to 
"reinitialize"  the  filter  by  setting  the  gains  to  G(0),  if 
certain  conditions  were  met.   After  several  trial  and  error 
runs,  it  was  determined  that  if  a  statistics  window  of  10 
were  used,  and  the  gains  reinitialized  if  the  error  ellipse 
area  increased  consecutively  a  certain  number  of  times , 
that  the  filtered  track  would  follow  around  the  curve. 
Figure  5.19  is  the  filtered  track  using  a  statistics  window 
of  10  and  reinitializing  the  filter  if  the  error  ellipse  area 
increased  consecutively  during  five  1-second  increments. 
The  error  ellipses  for  that  run  are  shown  in  Figures  5.20 
and  5.21.   As  indicated  on  the  figures,  the  filter  was 
reinitialized  four  times  and  the  ellipse  areas  for  the 
10-second  increments  increased,  until  reinitializing  the 
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filter  at  time  52  locked  the  filter  in.   Consequently  the 
error  ellipse  areas  for  time  6  0  and  70  decreased,  indicating 
convergence . 

In  the  final  run,  the  filter  was  reinitialized  after  10 
consecutive  1-second  error  ellipse  increases,  with  all  other 
parameters  remaining  zhe    same.   Figure  5.2  2  is  the  filtered 
track;  Figures  5.23  and  5.24  are  the  error  ellipse  plots 
for  this  run.   As  indicated  on  Figure  5. 24  the  filter  was 
reinitialized  only  once  at  time  57 .   A  comparison  of  ellipse 
areas  for  the  last  two  runs  shows  that,  with  the  exception 
of  time  70,  the  areas  were  larger  in  the  first  run  when  the 
filter  was  reinitialized  4  times.   This  is  expected  since 
reinitializing  results  in  larger  gains  producing  more  widely 
vary  estimates,  and  hence  greater  error  variance.   At  time 
70  the  error  ellipse  area  of  the  first  run  is  less  since  in 
the  first  run  the  last  filter  reinitialization  occurred  at 
time  52  versus  time  57  in  the  second  run.   The  first 
filtered  track  had  more  time  to  settle  out  by  time  70, 
resulting  in  less  error. 

B.   NONLINEAR  TRACKING 

Track  4  depicts  a  target  moving  at  a  constant  velocity 
of  50  feet  per  second  (30  kts )  in  the  x-direction  for  15 
seconds,  at  which  time  the  target  turns  and  travels  in  the 
-y-direction.   (See  Figure  5.25)   Using  the  extended  Kalman 
filter  with  o_^   =30  and  R  =  900,  a  series  of  tracking  runs  were 
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2 
made  for  various  values  of  COVW  (a  =from  20  to  200).   In  none 

w 

of  these  runs  did  the  filter  successfully  track  the  target 
around  the  turn.   Figure  5.26  shows  the  results  for  the  case 
when  COVW=150.   In  this  instance  the  filter  lost  track  as  the 
target  came  out  of  the  turn.   Trying  to  track  through  a  turn 
using  a  constant  COVW  (and  hence,  a  constant  Q)  did  not  work. 
So  a  scheme  was  devised  to  vary  COVW  dependent  on  information 
derived  from  the  error  ellipse.   After  several  trial  runs  for 
this  particular  track,  it  was  determined  that  if  the  error 
ellipse  area  increased  consecutively  for  7  iterations  of 
k,  COVW  would  be  doubled,  and  if  the  ellipse  area  decreased 
consecutively  for  5  iterations  of  k,  COVW  would  be  halved. 
Initially  the  the  trial  runs  were  made  without  a  statistics 
window,  and  the  filter  did  not  track  successfully.   Without 
the  statistics  window,  the  old  data  weighted  down  the  statis- 
tics, and  the  error  ellipses  were  not  indicative  of  what  was 
currently  happening.   So  it  was  decided  to  use  a  statistics 
window.   Windows  of  5,  10,  and  15  were  tried.   Window  5 
proved  to  be  too  responsive  and  window  15  not  responsive 
enough.   So  a  statistics  window  of  10  was  chosen  for  the 

tracking  run.   With  P  =102,  a  =30,  R=900,  and  COVW  initially 
&  — o       —v      —     '  J 

set  at  20,  the  tracking  run  was  made.   Figure  5.27  depicts 
the  filtered  track  output,  and  Figures  5.28-5.3  0  are  the 
10-second  incremental  error  ellipses  for  the  run.   As 
can  be  seen,  the  filter  did  track  around  the  curve.   Figure 
5.29  shows  the  ellipse  areas  are  becoming  less  between  times 
5  5  and  65.   Also  indicated  below  the  plots  are  the  values  of 
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COVW  for  the  k  time  the  plot  was  computed.   During  this 
particular  run  COVW  varied  from  an  initial  value  of  20  up 
to  16  0,  and  then  decreased  to  4-0  by  the  end  of  the  run. 

Using  the  same  filter  parameters  as  above  except  a_  was 
increased  to  200,  and  R  to  4  0,000,  another  run  was  made.   The 
filter  did  not  track  at  all.   During  this  run  COVW  varied 
from  an  initial  value  of  20  up  to  40  and  decreased  to  5  by 
the  end  of  the  run.   Obviously,  the  criteria  for  increasing 
and  decreasing  COVW  was  not  effective.   More  trial  runs  were 
necessary  to  determine  the  optimum  consecutive  increases 
or  decreases  of  the  ellipse  areas  before  adjusting  COVW 
accordingly . 

A  second  approach  to  the  nonlinear  tracking  problem,  one 
that  was  used  earlier  for  the  linear  case,  is  to  reinitialize 
the  filter  if  certain  conditions  are  met.   Again,  using 
trail  and  error  runs  with  and  without  statistics  windows, 
it  was  determined  that  using  a  statistics  window  of  10  gave 

the  best  results.   Using  initial  conditions  of  COVW-150, 

2  .... 

P  =10  ,  a    =30,  and  R=900,  several  runs  were  made,  reimtializ- 
— o       —v         — 

ing  the  filter  if  the  error  ellipse  area  increased  consecu- 
tively for  a  certain  number  of  iterations  of  k.   Of  the  runs 
attempted,  the  best  results  were  obtained  when  the  filter  was 
reinitialized  if  the  area  increased  for  5  consecutive 
iterations  of  k.   Figure  5.31  is  the  filtered  track  for  this 
run,  and  Figures  5  .  32-5  .  34-  are  the  error  ellipse  plots. 
Indicated  below  the  plots  are  the  times,  k,  when  the  filter 
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was  reinitialized.   For  this  particular  run  the  filter  was 

reinitialized  5  times.   It  should  be  noted  that  when 

2 
reinitializing  the  filter,  P(k/k-l)  was  reset  to  10   x  ?  . 

P   was  not  large  enough  to  be  effective  in  getting  the 

2 
filter  back  on  track.   The  initial  value  of  10   was  used  for 

P   to  reflect  the  high  confidence  in  the  initial  state 
— o  to 

conditions.   Other  values  of  P   did  not  work  as  well. 

— o 

Using  the  same  parameters  as  above  except  the  filter  was 
reinitialized  after  7  consecutive  error  ellipse  area 
increases,  another  run  was  made  with  the  resulting  track 
depicted  in  Figure  5.35.   A  comparison  with  Figure  5.31 
reveals  that  using  7  area  increases  as  the  criterion  for 
filter  reinitialization  resulted  in  poorer  filter  performance, 
as  can  be  shown  from  the  error  ellipses. 

The  final  nonlinear  filter  tracking  runs  attempted 
involved  simultaneously  varying  COVW  and  filter  reinitializa- 
tion.  The  results  were  disastrous,  and  highly  unpredictable. 
It  was  an  interesting  experiment  in  futility,  and  no 
meaningful  results  could  be  obtained. 
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Figure  5.1   Solid  Line  Track  1,  Vel  223.6  ft/sec;  Dots 
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Figure  5.2   Filtered  Track  1  Error  Ellipses  at  10  Second 

Increments,  a    =150 
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5.3   Filtered  Track  1  Error  Ellipses  at  10  Second 
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Figure    5.4      Filtered   Track    1,    a    =300 
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Figure  5  .  5 


Filtered  Track  1  Error  Ellipses  for  a  =300 
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Figure  5.6   Filtered  Track  1  Error  Ellipses  for  o_v=300, 
Using  Statistics  Window  of  10 
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Figure  5.7   Filtered  Track  1  Error  Ellipses  for  a    =300 


Using  Statistics  Window  of  5 
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Figure  5.8   Filtered  Track  1  Error  Ellipse  for  a  =400 
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Figure    5.9      Solid    Line   Track    2,    Vel    500    ft/sec,    Dots    Indicate 

Filtered  Track    for   a    =150,    a    =1,    R=20,000 
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Figure    5.10      Filtered   Track    2    Error   Ellipses,    a    =150 
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Figure    5.11      Filtered   Track    2    Error   Ellipses,    a_   =150 
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Figure    5.12 
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Figure  5  .13 


Filtered  Track  2  Error  Ellipses,  a_   =150,  Error 
Normalized 
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Figure  5.14 


Solid  Line  Track  3,  Vel  200  ft/sec,  Dots 
Indicate  Filtered  Track  for  a  =150 
R=20  ,000 
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Figure  5.15   Filtered  Track  3  Error  Ellipses,  a  =150 
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Figure  5.16 


Filtered  Track  3  Error  Ellipses,  a    =150, 
Statistics  Window  10 
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Figure    5  .17 


Filtered   Track    3    Error    Ellipses,    a    =150, 
Statistics   Window    5 
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Figure    5.18      Filtered   Track    3    for    a    =300,    a    =10,    R=20,000 
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Figure  5.19   Filtered  Track  3  for  a_   =  300 
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Figure    5.20      Filtered   Track    3    Error    Ellipses,    a    =300, 
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Figure  5.21   Filtered  Track  3  Error  Ellipses,  a  =300, 

Statistics  Window  10,  Reinitialize  5 
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Figure  5.22   Filtered  Track  3  for  a  =300,  a  =10,  R=20,000 
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igure  5.23   Filtered  Track  3  Error  Ellipses,  a  =300, 
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Figure  5.24   Filtered  Track  3  Error  Ellipses,  o^  =300 
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Figure  5  o  25   Track  4,  Vel  50  ft/sec 
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Figure  5.26   Filtered  Track  4, 
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Figure  5.27   Filtered  Track  4,  a  =30,  R=900,  Statistics 
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Figure  5.28   Filtered  Track  4  Error  Ellipses,  Statistics 
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Figure  5.2  9 
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Figure  5.30   Filtered  Track  4  Error  Ellipses,  Statistics 

Window  10,  Varying  COVW 
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Figure  5.31 
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Figure  5.32   Filtered  Track  4  Error  Ellipses,  a    =30 


Reinitialize  5 


— v 


77 


Y-POS    (FT) 


103 


-103 


en 


X-PCS    (FT) 


in 

i 


in 


en 

53 


SIGV-30  R-900  COVW-150 


TIME  AREA(SQ  FT)  LEG.  RESET 


45  4383E+000  38 

55  6852E+000  55 

55  6495E+000 55 


Figure  5.33 
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Figure    5.34      Filtered   Track    M-    Error   Ellipses,    a_   =  30, 
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VI .   CONCLUSIONS  AND  RECOMMENDATIONS 

A.   ERROR  ELLIPSE 

The  filter  error  ellipse  proved  useful  as  a  tool  for 
indicating  filter  performance.   The  information  provided  by 
the  ellipse,  particularly  surface  area  changes,  was  used  to 
make  decisions  concerning  the  alteration  of  the  filter 
parameters.   Several  approaches  for  using  the  error  ellipse 
were  applied  to  both  the  linear  and  nonlinear  tracking 
problem  and  the  results  are  summarized  below: 


Procedure 


Statistics 
Window 


Normalized 

Error 

Ellipse 


Applicable 

Filter 

(Linear  or 
Extended) 

Both 


Comments 


Both 


Useful  in  keeping  the  error 
ellipse  current  and  responsive 
to  present  data.   The  ellipse 
reflects  most  recent  data;  old 
data  is  disregarded.   Beneficial 
when  making  a  decision  concerning 
filter  parameter  modification. 
Normally  a  better  indicator  of 
filter  convergence  or  divergence 
than  without  a  statistics  window. 

Aid  in  displaying  error  trends 
as  target  approaches  coordinate 
axis  or  origin.   Not  practical 
in  determining  filter  conver- 
gence/divergence due  to  rapid 
ellipse  changes  in  vicinity  of 
axes  . 
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Reinitialize  Linear- 
Filter-       Set  G(0) 
Increasing    Extended-Set 
Ellipse  Area  P(k+l./k)  = 

10 n  x  P 
— o 


Error 
Ellipse 
Expansion/ 
Compression 
to  vary  COVW 
(Adaptive  Q) 


Extended 


Use  increasing  ellipse  size  as  an 
indicator  of  divergence,  and  as  a 
decision-making  device  to 
reinitialize  filter.   Particularly 
valuable  later  in  track  when  gains 
and  P(k+1/K)  have  settled  out. 
More  effective  when  used  in 
conjunction  with  statistics  window, 


This  techni 
based  on  er 
crease  or  d 
useful  in  a 
containing 
random  fore 
dure  is  mor 
in  conjunct 
window.  Us 
with  filter 
unsuccessf u 


que  of  varying  COVW 
ror  ellipse  area  in- 
ecrease  is  particularly 

tracking  environment 
large  variations  in  the 
ing  input .   The  proce- 
e  effective  when  used 
ion  with  a  statistics 
ing  this  technique 

reinitialization  was 
1. 


B.   COMPUTER  PERFORMANCE 

The  HP-86  proved  to  be  an  extremely  reliable  computer 
with  no  downtime  experienced  during  the  5  month  period  of 
operation.   Full(Real)  precision  was  used  throughout  the 
study  providing  15  digit  precision,  which  was  more  than 
adequate.   The  use  of  the  Matrix  ROM  reduced  program  length 
by  90%  and  increased  computing  speed  by  a  factor  of  about  6. 
Although  not  used  in  this  study,  a  Statistics  ROM  would  have 
undoubtedly  further  increased  computing  speed.   For  any 
further  study  using  the  HP-86,  it  is  recommended  that  a 
Statistics  ROM  be  procured. 

It  took  approximately  2  seconds  for  each  incremental 
time  measurement  data  to  be  sequenced  through  the  filter 
equations,  both  for  the  linear  and  nonlinear  case.   This 
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computing  time  also  included  all  statistics  computations. 
With  an  incoming  data  rate  of  1  set  of  measurement  data  per 
second,  this  computing  speed  is  not  sufficient  for  on-line 
processing.   As  previously  mentioned,  the  Naval  Underwater 
Tracking  Range  receives  a  series  of  4  measurement  times 
sequentially  every  1.31  seconds.   The  range's  three- 
dimensional  tracking  problem  will  necessarily  involve  more 
than  the  4  state  variables  used  in  this  study.   Hence 
greater  matrix  dimensions  resulting  in  longer  computing 
times  can  be  expected. 

The  HP-86  CRT  graphics  were  used  extensively  to  provide 
error  ellipse  plots  during  the  tracking  runs.   Using  a  "no 
frills"  approach  to  plotting,  i.e.  plotting  without  x-y 
axis  or  labelling,  it  took  approximately  2.5  seconds  per 
ellipse  plot.   The  ellipse  plotting  routine  used  involved 
sines  and  cosines,  plotted  point  by  point  in  30  degree 
increments  for  a  total  of  360  degrees.   This  method  was 
somewhat  slow.   Had  there  been  available  a  graphics  program 
that  would  sketch  in  the  ellipse  around  the  intersected 
major  and  minor  axis,  the  graphics  presentation  could  have 
been  speeded  up.   But  since  ellipse  plotting  for  every  3  to 
5  increments  of  time  provided  sufficient  "real-time" 
information,  the  time  of  2.5  seconds  per  plot  was  tolerable. 

Summarizing,  the  HP-86  could  be  used  to  compute 
statistics  and  provide  graphics  in  the  real-time  underwater 
tracking  environment,  if  the  graphics  were  required  not  more 
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often  than  3  to  5  seconds.   However,  before  the  HP-8  6  can  be 
considered  feasible  for  real-time  Kalman  filter  processing, 
more  investigation  is  needed  in  finding  ways  to  speed  up 
computer  processing  time  such  as  parallel  processing, 
additional  use  of  manufacturer-provided  ROMs  and  machine 
language  programming. 
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APPENDIX  A 
TRACK  GENERATION 

1.   TRACK  THREE 

Target  movement  is  in  the  x-y  plane  with  the  tracking 
sensor  located  at  the  origin  of  the  cartesian  axes.   The 
target  follows  a  parabolic  track  (see  Figure  A-l)  at  a 
constant  speed  of  200  feet  per  second. 


y 


Figure  A-l   Track  3 
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The  parabolic  equation  is 


yZ  =  M-p(x-h) 


where  p  =  1000  and  h  =  1000,  resulting  in 


y2  =  4000(x-1000) 


Initial  target  location  is  (x,y)  =  (8000,  5291.5).   Target 
x-direction  velocity  is  given  by: 


v   =  v  cos(Angle)  (A-l) 

x  to 


and  target  y-direction  velocity  is 


v   =  v  sin(Angle)  (A-2) 

y 


where  the  Angle  is  obtained  from 


Angle  =  tan-1(^) 
&  Ax 


and  v  is  obtained  from 


,    2     2,1/2 
v  =  (v   +  V  ) 
x    y 
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where  the  argument  of  the  inverse  tangent  is  the  slope  of  a 
small  increment  (less  than  1  second)  at  each  successive  data 
point.   Using  a  sampling  period  of  one  second,  the  data 
points  (x,y)  can  be  obtained  from: 


x(k+l)  =  x(k)  +  v  (k) 

x 


y(k+l)  =  y(k)  +  v  (k) 

y 


Table  A-l  gives  the  numerical  values  for  the  four  states  . 

2.   TRACK  FOUR 

Target  movement  simulates  a  30-knot  torpedo  (velocity  50 

feet  per  second)  at  a  constant  depth.   The  target's  initial 

position  is  (x,y)  =  (3250,  5000),  and  it  is  moving  in  the  v 

direction  with  v  =0.   (See  Figure  A-2.)   The  target  remains 

y  °  ° 

on  a  straight  course  for  15  seconds,  and  then  executes  a  90 
degree  turn  and  travels  in  the  -y  direction  at  v  =  -50  ft/sec. 

y 

The  trajectory  of  the  target  turn  is  described  by  a  90  degree 

arc  of  a  circle  of  radius,  R  =  1000,  with  the  circle  centered 

at  (x,y)  =  (4000,  4000).   The  90  deg  arc  will  be  traversed 
in: 

2ttR/4v  sec.  =  IOtt  sec. (where  v  =  50  ft/sec) 
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TABLE  A-l 
NUMERICAL  VALUES  OF  STATES  FOR  TRACK  THREE 

K  X         X-VEL         Y  Y-VEL 


1 

8000. CO 

-  1 86  .  9  0 

5291. 50 

-71.15 

2 

7813.  10 

-186.93 

5220. 38 

-71.13 

3 

7626.17 

-186.60 

5148.  27 

-71.98 

•4 

7439.58 

-  186.25 

5075*  26 

-72.37 

5 

7253.33 

-185.89 

5001. 33 

-73.79 

6 

7067.44 

-185.5  1 

4926. 43 

-74.74 

7 

6881.93 

-185.11 

4850. 54 

-75.73 

8 

6696. 82 

-  184.6  8 

4773. 60 

-76.76 

9 

6512.14 

-  1 84  .  2  4 

4695. 59 

-77.33 

10 

6327.90 

-183.76 

4616. 45 

-78.94 

11 

6144.  14 

-183.26 

4536.  14 

-80.09 

12 

5960. 87 

-182.  73 

4454. 60 

-81.30 

13 

5778.  14 

-182.  17 

4371.79 

-82.56 

14 

5595.98 

-181.57 

4287. 65 

-83.87 

15 

5414. 41 

-180.92 

4202.  10 

-85.24 

16 

5233.49 

-180.  24 

4115. 09 

-86.68 

17 

5C53.25 

-179.51 

4026. 54 

-88.19 

18 

4873. 74 

-178.  72 

3936. 37 

-89.73 

1S 

4695.02 

-177.87 

3844. 49 

-91.44 

20 

4517.  15 

-176.  96 

3750. 81 

-93.19 

21 

4340.  19 

-175.97 

3655. 24 

-95.04 

22 

4  164.  22 

-  174.  9  1 

3557. 65 

-97.00 

23 

3S89.31 

-173.74 

3457. 93 

-99.06 

24 

3815.57 

-172.  48 

3355. 93 

-101.25 

25 

3643.09 

-171  .09 

3251. 52 

-103.57 

26 

3472. 00 

-  169.57 

3144. 52 

-106.05 

27 

3302.43 

-167.89 

3034. 75 

-108.68 

28 

3134.54 

-166.  04 

2922. 01 

-1  11.50 

29 

2968. 5C 

-163.98 

2806. 06 

-1  14.51 

30 

2804.52 

-  161.  67 

2686. 65 

-1  17.74 

31 

2642. 65 

-159.09 

2563. 47 

-121.21 

32 

2483. 76 

-156.  17 

2436. 20 

-124.94 

33 

2327.59 

-152.86 

2304. 42 

-128.98 

34 

2174. 74 

-149.07 

2167. 70 

-133.33 

35 

2C25.66 

-144.72 

2025. 50 

-138.05 

36 

1880. 95 

-139.67 

1877.  18 

-143.15 

37 

1741.28 

-133.78 

1721. 95 

-148.67 

38 

1607. 50 

-  126.  8  3 

1558. e5 

-154.64 

3S 

1480.67 

-118.59 

13  86. 61 

-161.05 

40 

1362. 08 

-108.70 

1203.  46 

-167.38 

41 

1253.38 

-96.73 

1006. 73 

-175.05 

42 

1156. 6  5 

-82.01 

791. 58 

-182.41 

43 

1C74.64 

-63.4  4 

546. 41 

-189.67 

44 

1011. 20 

-37. 24 

211. 63 

-196.50 

45 

1000. CC 

0.00 

0.  00 

-200.00 
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TABLE  A-l  (CONT. ) 


K 


X 


X-VEL 


Y 


Y-VEL 


46 
47 
48 
49 
50 
51 
52 
53 
54 
5  5 
56 
57 
58 
59 
60 
61 
62 
63 
64 
65 
66 
67 
68 
69 
70 
71 
72 
73 
74 
75 
76 
77 
78 
79 
80 
81 
82 
83 
84 
85 
86 
87 
88 
89 
90 


1011. 

20 

1C21. 

,77 

1046. 

90 

1082. 

,72 

1131. 

6  1 

1193. 

,46 

1267. 

C  e; 

1354. 

,31 

1451. 

56 

1558. 

,6C 

1674. 

35 

1797. 

,76 

1927. 

94 

2C64. 

,01 

2205. 

24 

2351. 

,02 

2500. 

60 

2654. 

,  1  1 

2810. 

56 

2969. 

,8C 

3131. 

52 

3295, 

,49 

3461. 

47 

3629. 

,27 

3798. 

73 

3969. 

,69 

4  142. 

03 

4315. 

,63 

4490. 

38 

4666. 

,21 

4843. 

02 

5020. 

,74 

5199. 

32 

5378. 

,  66 

5558. 

78 

5739. 

,57 

5  921. 

01 

6103. 

,05 

6285. 

66 

6468. 

,  80 

6652. 

45 

6836. 

,56 

7021. 

16 

7206. 

,  16 

7391. 

,  57 

10.  57 

-211. 

63 

-199.72 

25.  14 

-295. 

07 

-198.41 

35.  8  2 

-433. 

13 

-196.77 

48.8  9 

-575. 

23 

-193.93 

61.85 

-725- 

57 

-190.20 

74  .4  9 

-879. 

69 

-185.61 

86 .  36 

-1035. 

28 

-180.39 

97.25 

-1 190. 

48 

-174.77 

107.04 

-1343. 

96 

-168.94 

115.75 

-1494. 

80 

-163.  10 

123.  4  3 

-1642. 

38 

-157.37 

130.  16 

-1786. 

37 

-151.35 

136. 06 

-1926. 

60 

-146.58 

141  .24 

-2063. 

01 

-141.61 

145.78 

-2195. 

67 

-136.92 

149.78 

-2324. 

67 

-132.54 

153.  31 

-2450. 

14 

-128.43 

156.4  5 

-2572. 

25 

-124.60 

159.  24 

-2691. 

14 

-121.01 

161.73 

-2806. 

99 

-1 17. 66 

163. 97 

-2919. 

95 

-1 14.52 

165.98 

-3030. 

17 

-1 11.53 

167. 80 

-3137. 

81 

-108.32 

169.46 

-3243. 

01 

-106.23 

170. 96 

-3345. 

68 

-103.79 

172.34 

-3446. 

56 

-101.49 

173.60 

-3545. 

15 

-99.32 

174.76 

-3641. 

77 

-97.26 

175.  8  2 

-3736. 

51 

-95.32 

1 76  .  8  1 

-3829. 

47 

-93.48 

177.  73 

-3920. 

72 

-91 .73 

178.57 

-4010. 

36 

-90.06 

179.  36 

-4098. 

45 

-88.48 

180.  10 

-4  185. 

06 

-86.97 

180. 79 

-4270. 

26 

-85.53 

181 . 44 

-4354. 

11 

-84.15 

182. 04 

-4436. 

67 

-82.83 

182. 61 

-4517. 

99 

-81 .57 

183.  14 

-4598. 

11 

-80.36 

183.65 

-4677. 

09- 

-79.20 

184.  13 

-4754. 

98 

-78.09 

184.5  8 

-4831. 

80 

-77.01 

185.00 

-4907. 

61 

-75.98 

185.41 

-4982. 

43 

-74.99 

185.  79 

-5056. 

31 

-74.03 

89 


Y 


So  each  second 


Figure  A-2   Track  4 


X 


2ttM 
IOtt 


=  .05  radians  will  be  traversed 


Using  the  trigonometric  identity: 


sin2(A)  +  cos2(A)  =  1 


90 


And  the  equation  for  a  circle 


2     2     2 
x   +  y   =  c 


It  follows  that  the  arc  of  Figure  A-2  is  described  by 


x(k)  =  4000  +  1000sin( ,05k) 

y(k)  =  4000  +  1000cos( .05k) 

where  the  angle  argument  is  in  radians  and  k  =  0  , 1 ,  2  ,  . . . 31 

seconds.   The  velocities  v   and  v   can  be  obtained  from: 

x       y 

v  (k)  =  50cos( .05k) 
x 

v  (k)  =  -50sin(.05k) 

y 

using  the  same  angle  argument. 

The  track  values  for  the  track  arc  are  contained  in  Table 

A-2. 
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TABLE    A-2 


NUMERICAL    VALUES    CF    STATES    FOR    TRACK    FOUR 


K 


X-VSL 


Y-VEL 


12 

3049  .9$ 

49.9  8 

4999. 38 

-  1.25 

13 

3099.96 

49.  9  4 

4997. 50 

-2.  50 

14 

3149.66 

49.86 

4994. 38 

-3.75 

15 

3199.67 

49.75 

4990. 01 

-4.  99 

16 

3249.35 

49.  6  1 

4984. 40 

-6.  23 

17 

3298.88 

49.4  4 

4977. 54 

-7.47 

18 

3343. 22 

49.  24 

4969. 45 

-8.71 

1S 

3397.34 

49.0  0 

4960.  13 

-9.93 

20 

3446.21 

48.74 

4949. 59 

-11.16 

21 

3494  .61 

48.4  5 

4937. 82 

-12.37 

22 

354  3.  C< 

48.  1  2 

4924. 65 

-13.53 

23 

3591  .C4 

4^.77 

4910. 67 

-14. 73 

24 

3638.62 

47.  3  8 

4895. 30 

-15.97 

25 

3685. eC 

46.  97 

4878. 75 

-17.  14 

26 

3732.55 

46.  53 

4861. 02 

-18.31 

27 

3778.64 

46.0  5 

4842.  12 

-19.  47 

28 

3824.64 

45.  55 

4822. C8 

-20.62 

2S 

3869. S3 

45.02 

4800. 89 

-21.75 

30 

3914.68 

44.  46 

4778. 59 

-22.87 

31 

3958.65 

43.88 

4755.  17 

-23.97 

32 

4002.43 

43.27 

4730. 65 

-25.06 

33 

4045.37 

42.63 

4705. 05 

-26.  13 

34 
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APPENDIX  B 
COMPUTER  PROGRAM  EXPLANATION 

1.  LINKAL 

The  LINKAL  program  computes  the  filter  gains,  GAIN (4,2), 
for  the  4-state  system  and  stores  the  gains  in  "LINGAIN 
.STORAG".   The  theoretical  covariance  of  error  matrix,  PKK(4,4), 
is  also  computed  and  stored  in  "LINCOV . STORAG" .   Several 
different  sets  of  gain  and  covariance  values  were  computed 
and  stored  for  various  values  of  measurement  noise,  RMAT ( 2 , 2 ) , 
and  random  forcing  noise,  COVW(2,2). 

2.  LINEST 

The  LINEST  program  retrieves  the  appropriate  gain 
schedule  from  storage  and  computes  the  optimal  estimate, 
XHAT(4,1),  and  the  optimal  one-step  prediction,  XHK1K(4,1). 
The  following  capabilities  are  contained  in  the  LINEST  program: 

a .  Gating  Scheme 

If  the  absolute  difference  (DIFF)  between  the  one-step 
prediction,  XHK1K  and  the  noisy  track  value,  ZMAT ,  is  greater 
than  the  three-sigma  gate,  then  the  GAIN  matrix  is  disregarded 
and  XHAT  is  set  equal  to  XHK1K . 

b .  Track  Noise 

By  setting  NOITRAK  =  1,  the  random  number  generator, 
RND,  and  the  resulting  simulated  noise  produced,  VI  and  V2, 
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are  bypassed  and  the  track  values  corrupted  with  noise,  ZMAT , 
are  retrieved  from  data  file  "NOITRAK . STORAG" .   If  N0ITRAK=1, 
then  the  random  number  generator  is  "reseeded"  for  each 
program  run,  producing  a  different  set  of  noise  values 
resulting  in  a  unique  noise  corrupted  track  for  each  run. 

c .  Statistics  Window 

When  WINDOW  is  set  to  0,  the  filter  state  statistics 
are  computed  after  each  Monte  Carlo  run.   The  error  mean, 
variance  and  position  covariance  are  computed.   If  WINDOW 
is  set  to  an  integer,  I,  such  that  max  k>I>0,  the  statistics 
will  be  computed  based  on  the  data  compiled  during  the  last 
I  iterations  of  the  simulation.   If,  for  example,  WINDOW=10, 
the  computation  of  statistics  will  be  based  on  the  data 
obtained  during  the  last  ten  iterations  of  k,  and  all 
previous  data  is  disregarded. 

d .  Error  Normalization 

By  setting  NORM  =  1,  the  error  (ERR),  which  is 
defined  as  the  difference  between  the  true  track  value  (TRAK) 
and  the  estimate  (XHAT) ,  is  normalized.   For  all  other  values 
of  NORM  the  relative  error  is  used  in  computing  the 
statistics . 

e.  Reinitializing  Gains 


The  program  has  the  option  of  reinitializing  the  gains 
to  G(0).   This  can  be  done  by  setting  HIGH  to  an  integer  I, 
such  that  max  k>I>0.   If  the  surface  area  of  the  ellipse 
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increases  I  consecutive  times,  indicating  filter  divergence, 
the  gains  are  reinitialized  to  G(0).   If  reinitializing 
gains  is  not  desired  as  an  option,  then  HIGH  is  set  to  some 
arbitrary  large  number  greater  than  max  k. 

3.   EXTKF 

The  EXTKF  program  computes  the  optimal  estimate,  XHAT , 
and  the  optimal  one-step  prediction,  XHK1K,  for  the  4—  state 
nonlinear  tracking  problem.   The  EXTKF  program  has  the 
options:   gating  scheme,  track  noise,  statistics  window, 
and  error  normalization  as  described  for  the  LINEST  program. 
EXTKF  has  the  following  additional  options: 

a .  Reinitializing  the  Filter 

The  program  has  the  option  of  reinitializing  the 

covariance  of  one-step  prediction  error  matrix,  PK1K,  by 

setting  it  to  10-xP  ,  where  n  is  zero  or  some  small  integer. 

If  HIGH  is  set  to  an  Integer  I,  such  that  max  k>I>0,  and  the 

surface  area  of  the  ellipse  increases  I  consecutive  times, 

then  the  PK1K  matrix  will  be  reset  to  10  xP  . 

— o 

b .  Adaptive  Q 

EXTKF  has  the  option  of  automatically  increasing  or 
decreasing  the  state  excitation  matrix,  Q_,  under  certain 
conditions  by  changing  the  value  of  the  covariance  of 
excitation  noise,  COVW0   INCREASE  and  DECREASE  are  set  to 
integers  I  and  J  respectively,  such  that  max  k>I,J>0.   If 
the  surface  area  of  the  error  ellipse  increases  I 
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consecutive  times,  COVW  is  doubled  or  increased  by  some 
factor.   Conversely,  if  the  surface  area  of  the  error  ellipse 
decreases  J  consecutive  times,  COVW  is  halved  or  decreased 
by  some  factor.   If  COVW  is  changed,  increased  for  example, 
the  value  of  COVW  can  be  changed  again  later  in  the  run, 
if  the  criteria  for  either  increasing  or  decreasing  is  met. 
If  the  adaptive  Q  is  not  desired  then  INCREASE  and  DECREASE 
are  set  to  some  large  number  greater  than  k. 
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APPENDIX  C 
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